<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <!-- 导入依赖 -->
    <script src="https://lib.baomitu.com/leaflet/1.9.2/leaflet.js"></script>
    <link rel="stylesheet" href="https://lib.baomitu.com/leaflet/1.9.2/leaflet.css">
    <style>
        * {
            margin: 0;
            padding: 0
        }

        #map {
            width: 100vw;
            height: 100vh;
        }

        #btn {
            position: fixed;
            z-index: 1000;
            width: 200px;
            height: 60px;
            top: 10px;
            right: 30px;
        }
    </style>
</head>

<body>
    <button id="btn" onclick="clearMarker()">清除标注</button>
    <div id="map">

    </div>
    <script>
        /* 加载瓦片地图 */
        var url = 'https://api.mapbox.com/styles/v1/mapbox/streets-v11/tiles/{z}/{x}/{y}?access_token=pk.eyJ1IjoiY2hlbmdiZW5jaGFvIiwiYSI6ImNsODU3aGRiODA0Y2UzcHBzZmFlcmdqZ2sifQ.8k59W_pB_Riwe6o-MneRlA'
        var layer = L.tileLayer(url, {
            maxZoom: 19,
            attribution: '© OpenStreetMap'
        })
        const map = L.map("map", {
            layers: [layer],
            /* center:[纬度,经度] */
            center: [30.50, 114.30],
            zoom: 4
        })
        // let marker = L.marker([30.50, 114.30]);
        // map.addLayer(marker);
        /* 点击事件添加marker */
        let arr = []
        map.on("click", evt => {
            var { lng, lat } = evt.latlng;
            let marker = L.marker([lat, lng]);
            arr.push(marker);
            map.addLayer(marker)
            // 此处每个marker都是一个图层
            // 把数组当作对这些marker图层的管理器来用
        })

        function clearMarker() {
            // console.log(map);
            // console.log(map._layers);
            // 在map._layers属性上可以找到由所有图层组成的对象。
            // 此种方法，创建一个新的标记都是一个新的图层，
            // 添加多少个标记，就会增加多少个图层。

            /* 获取所有的标记图层 */
            // console.log(arr)
            // !!! 每一个图层都有一个remove方法 layer.remove() 可以从地图上移除图层
            arr.forEach(item => {
                item.remove();
            })
        }
    </script>
</body>

</html>